Eager Loading এবং Explicit Loading কৌশল

Microsoft Technologies - এন্টিটি ফ্রেমওয়র্ক (Entity Framework) Entity Relationships এবং Navigational Properties |
160
160

Entity Framework (EF) এ ডেটা লোড করার সময় বিভিন্ন লোডিং কৌশল ব্যবহার করা হয়, যার মাধ্যমে সম্পর্কিত ডেটা দ্রুত এবং কার্যকরীভাবে লোড করা যায়। Eager Loading এবং Explicit Loading দুটি জনপ্রিয় কৌশল, যা EF এ সম্পর্কিত ডেটা লোড করার জন্য ব্যবহৃত হয়।


Eager Loading

Eager Loading হলো একটি কৌশল যেখানে সম্পর্কিত ডেটা প্রাথমিক কুয়েরির সাথে একসাথে লোড করা হয়। এটি মূলত তখন ব্যবহৃত হয় যখন আপনি নিশ্চিত হতে চান যে মূল অবজেক্ট এবং এর সম্পর্কিত অবজেক্টগুলো একই সময়ে লোড হবে। EF এ Eager Loading সাধারণত Include() মেথডের মাধ্যমে সম্পন্ন হয়।

Eager Loading এর সুবিধাসমূহ

  • পারফরম্যান্স বৃদ্ধি: একাধিক কুয়েরি না চালিয়ে একসাথে সমস্ত সম্পর্কিত ডেটা লোড করা যায়, যা কার্যকরী হতে পারে যখন সম্পর্কিত ডেটা প্রয়োজন হয়।
  • ব্লোকে ডেটা লোড করা: ডেটা লোডের জন্য একাধিক রাউন্ড ট্রিপের প্রয়োজন হয় না, ফলে অ্যাপ্লিকেশনটি আরও দ্রুত কাজ করতে পারে।

Eager Loading এর উদাহরণ

ধরা যাক, একটি Customer ক্লাস এবং একটি Order ক্লাস আছে, যেখানে Customer এর সাথে একাধিক Order সম্পর্কিত রয়েছে।

var customersWithOrders = context.Customers
                                  .Include(c => c.Orders) // Eager loading to include related Orders
                                  .ToList();

এই কুয়েরি Customer এবং তার সমস্ত Order একসাথে লোড করবে। Include() মেথডটি আপনাকে Customer এর সাথে সম্পর্কিত Orders ডেটা একসাথে লোড করার অনুমতি দেয়।

একাধিক সম্পর্ক লোড করা

আপনি একাধিক সম্পর্কও Eager Loading এর মাধ্যমে লোড করতে পারেন:

var customersWithOrdersAndPayments = context.Customers
    .Include(c => c.Orders)
    .Include(c => c.Payments)
    .ToList();

এখানে Customer এর সাথে Orders এবং Payments সম্পর্কিত ডেটা একসাথে লোড করা হবে।

সমস্যা

Eager Loading এর সমস্যা হতে পারে N+1 Query Problem। যখন আপনি Include() ব্যবহার করেন, তখন EF প্রতিটি সম্পর্কের জন্য আলাদা কুয়েরি চালাতে পারে, বিশেষত যখন আপনি একাধিক সম্পর্কের ডেটা লোড করেন।


Explicit Loading

Explicit Loading হলো একটি কৌশল যেখানে সম্পর্কিত ডেটা সুনির্দিষ্টভাবে পরবর্তীতে লোড করা হয়, এর মাধ্যমে আপনি সম্পর্কিত ডেটাকে আপনার প্রয়োজনের ভিত্তিতে এক্সপ্লিসিটলি লোড করতে পারেন। EF এ Explicit Loading সাধারনত Load() মেথড ব্যবহার করে করা হয়, এবং এটি তখন ব্যবহৃত হয় যখন আপনি সম্পর্কিত ডেটা শুধুমাত্র তখন লোড করতে চান, যখন তা প্রয়োজন।

Explicit Loading এর সুবিধাসমূহ

  • বিকল্প ডেটা লোড: আপনি যখন জানেন না যে, আপনার কিভাবে সম্পর্কিত ডেটা লোড করার প্রয়োজন হবে, তখন Explicit Loading ব্যবহার করা হয়। এতে আপনি ডেটাকে চাহিদামতো লোড করতে পারেন।
  • সম্পর্কিত ডেটা বিলম্বিত লোড করা: সমস্ত সম্পর্কিত ডেটা একসাথে লোড না করে প্রয়োজন অনুযায়ী ডেটা লোড করা সম্ভব হয়, যা অনেক ক্ষেত্রে পারফরম্যান্সের জন্য ভালো হতে পারে।

Explicit Loading এর উদাহরণ

ধরা যাক, একটি Customer ক্লাস এবং একটি Order ক্লাস রয়েছে। আপনি প্রথমে Customer লোড করবেন এবং তারপর সম্পর্কিত Orders ডেটা পরবর্তীতে লোড করবেন।

var customer = context.Customers.FirstOrDefault(c => c.CustomerId == 1);

// Explicitly load the related Orders data
context.Entry(customer)
       .Collection(c => c.Orders)
       .Load();

এখানে প্রথমে Customer লোড করা হয়েছে এবং পরবর্তীতে Orders সম্পর্কিত ডেটা লোড করা হয়েছে। Entry() মেথডটি সম্পর্কিত ডেটার প্রপার্টি নির্বাচন করার জন্য ব্যবহৃত হয় এবং Load() মেথডটি সম্পর্কিত ডেটা লোড করে।

Nullable প্রপার্টির জন্য Explicit Loading

যদি আপনার প্রপার্টি Nullable হয়, তবে Include() ব্যবহার করা যাবে না, এই ক্ষেত্রে Explicit Loading ব্যবহার করাই সবচেয়ে উপযুক্ত পদ্ধতি।

var customer = context.Customers.FirstOrDefault(c => c.CustomerId == 1);

// Explicitly load the related Address, which might be nullable
context.Entry(customer)
       .Reference(c => c.Address)
       .Load();

এখানে Address প্রপার্টি Nullable হতে পারে, তাই Explicit Loading ব্যবহার করা হয়েছে।


Eager Loading বনাম Explicit Loading

বৈশিষ্ট্যEager LoadingExplicit Loading
লোডিং টাইমডেটা একসাথে লোড করা হয়।সম্পর্কিত ডেটা পরবর্তীতে লোড করা হয়।
পারফরম্যান্সএকাধিক রাউন্ড ট্রিপ এড়ানো যায়, তবে N+1 Query সমস্যা হতে পারে।শুধুমাত্র যখন প্রয়োজন, তখন ডেটা লোড হয়।
কোডের জটিলতাসহজ, তবে কিছু ক্ষেত্রে অপটিমাইজেশন প্রয়োজন।কোডে আরও জটিলতা থাকে, তবে নির্দিষ্ট পরিস্থিতিতে ভালো।
ডেটা অ্যাক্সেসের নিয়ন্ত্রণকম নিয়ন্ত্রণ (একই সময়ে সব সম্পর্কিত ডেটা লোড হয়)।বেশি নিয়ন্ত্রণ (কখন, কোথায়, কীভাবে ডেটা লোড হবে তা নিয়ন্ত্রণ করা যায়)।

উপসংহার

Eager Loading এবং Explicit Loading দুটি গুরুত্বপূর্ণ কৌশল, যা Entity Framework এর সাথে সম্পর্কিত ডেটা লোড করার জন্য ব্যবহৃত হয়। আপনি যদি জানেন যে সম্পর্কিত ডেটার প্রয়োজন, তবে Eager Loading ব্যবহৃত হতে পারে, তবে যদি সম্পর্কিত ডেটা প্রয়োজন না হয় বা পরবর্তীতে লোড করতে চান, তবে Explicit Loading ব্যবহার করা উচিত।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion